<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .father {
            height: 100px;
            width: 100px;
            background-color: aqua;
        }

        .son {
            height: 50px;
            width: 50px;
            background-color: pink;
        }
    </style>
</head>

<body>
    <div class="father">
        <div class="son">son 盒子</div>
    </div>
    <script>
        // dom 事件流 三个阶段
        // 1. JS代码中只能执行捕获或者冒泡其中的一个阶段
        // 2. onclick 和 attach(ie) 只能得到冒泡阶段
        // 3. 捕获阶段 如果 addEventListener() 第三个参数是true 则处于捕获阶段
        // document -> html -> body -> father -> son
        // var son = document.querySelector('.son')
        // son.addEventListener('click', function () {
        //     alert('son')
        // }, true);
        // var father = document.querySelector('.father')
        // father.addEventListener('click', function () {
        //     alert('father')
        // }, true);
        // 4. 冒泡阶段 如果 addEventListener() 第三个参数是false或者省略 则处于冒泡阶段
        // son -> father -> html -> document
        var son = document.querySelector('.son')
        son.addEventListener('click', function () {
            alert('son')
        },false);
        var father = document.querySelector('.father')
        father.addEventListener('click', function () {
            alert('father')
        },false);
        document.addEventListener('click', function(){
            alert('document');
        },false);
    </script>
</body>

</html>